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(54) System for retrieving and printing network documents 



(57) A method for providing print-by-reference func- 
tionality includes providing a web page from a printer's 
embedded web server to a web browser, receiving a 



URL entered into the provided web page, retrieving a 
printable document corresponding to the URL, and 
printing the retrieved document. 
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Description 

[0001] The present invention relates to systems for 
printing documents and electronic mail located on the 
Internet or an intranet. In particular, the present inven- 
tion concerns systems for printing using a Universal Re- 
source Locator (URL) corresponding to a document or 
using electronic mailbox information corresponding to 
electronic mail. 

[0002] The Internet contains many documents avail- 
able for downloading to a user's computer. To access 
these documents, a user activates a web browser ap- 
plication residing on the computer and browses the 
World Wide Web through selection of hyperlinks within 
accessed web pages and/or by inputting specific URLs 
into the web browser. Once a desired document is 
found, the user selects the document and the document 
is downloaded to the user's computer for printing. 
[0003] Such documents are downloaded in a particu- 
lar format, such as Adobe PDF, Adobe Postscript, Mi- 
crosoft Word, or the like. In orderto print the downloaded 
document, the user opens the document in its associat- 
ed application and prints the document from the appli- 
cation. 

[0004] Recently, Internet Printing Protocol (IPP) has 
been developed to provide a system for printing by ref- 
erence to a document's corresponding URL. Using IPP, 
a URL is delivered from an IPP client (usually executing 
on the user's computer) to an IPP server (usually exe- 
cuting on a web server). Next, the IPP server retrieves 
a document corresponding to the received URL and, if 
necessary, renders the document into an appropriate 
printer format. The print-ready document is then deliv- 
ered to a printer for printing. One advantage of this print- 
by-reference functionality is that a user can retrieve and 
print a document without having first to access the web- 
site in which the document exists. 
[0005] One drawback of the foregoing IPP scheme is 
that both the user's computer and the web server require 
special IPP-enabling software to execute the IPP client 
and IPP server, respectively. However, many devices, 
such as Personal Digital Assistants (PDAs) have limited 
processing power and application storage space, there- 
fore the IPP scheme unacceptably consumes already 
scarce resources. Moreover, the IPP client software 
most likely includes an interface for inputting the URL 
and therefore requires a userto learn an interface in ad- 
dition to those already used by the user. 
[0006] Another drawback of the foregoing systems for 
printing arises because some websites containing print- 
able documents are only accessible using certain trans- 
fer protocols, such as File Transfer Protocol (FTP). As 
a result, using the first system described above, a web 
browser searching for Intemet/intranet-located docu- 
ments must be FTP-enabled, that is, the browser must 
be able to communicate using the FTP protocol. Again, 
for devices having scarce memory, such a browser, 
which also supports Hypertext Transfer Protocol (HT- 



TP), consumes more memory and computing power 
than a browser supporting only one protocol. 
[0007] Yet another drawback of the foregoing systems 
is that printable documents are often difficult to locate 
5 on Hypertext Markup Language (HTML) web pages 
browsed by a user, since many web pages contain vis- 
ually distracting colors, images and animations. 
[0008] Accordingly, what is needed is a system allow- 
ing print-by-reference functionality utilizing commonly- 

10 available software applications and a system in which 
print-by-reference functionality can be used to print doc- 
uments located on websites supporting a transfer pro- 
tocol which is not supported by a user's browser. In ad- 
dition, what is needed is a system in which printable doc- 
's uments on remote websites are presented to a user in 
an easily-understandable format. 
[0009] The present invention addresses the foregoing 
problems by providing a printer web page into which a 
user enters information corresponding to a network doc- 

20 ument or to electronic mail. Then, upon receipt of the 
information , the corresponding job is retrieved and print- 
ed. Accordingly, the present invention provides print-by- 
reference functionality to a user using the user's web 
browser, and without requiring special IPP software on 

25 the user's computer. 

[0010] In a further aspect, the present invention pro- 
vides a web page to a user into which the user enters a 
URL corresponding to a website. Notably, the transfer 
protocol used by the website is not supported by the us- 

30 efs browser. A web page is created based on the con- 
tents of the website, the web page including a link to a 
directory, a link to a document, or links to a directory and 
a document. As a result, a user can browse websites 
using a transfer protocol which is not supported by the 

35 user's browser. Accordingly, since the web browser is 
not required to support the transfer protocol of the web- 
site, a memory footprint of the browser can be reduced. 
Moreover, using the created web page, a user can more 
easily locate printable documents on the website. 

40 [0011] In another aspect, the present invention is di- 
rected to a system in which a printer web page is pro- 
vided to a web browser, a URL entered into the provided 
web page is received, the URL corresponding to a web- 
site having a transfer protocol not supported by the web 

45 browser, and a web page is created based on contents 
of the website, the web page including a link to a direc- 
tory, a link to a document, or links to a directory and a 
document. If a link to a directory is selected, a new page 
is created including a link to a subdirectory, a document 

50 or linked to a subdirectory and a document. 

[0012] By virtue of this aspect, a user can browse 
websites using a transfer protocol which is not support- 
ed by the user's browser. As mentioned above, a mem- 
ory footprint of the browser can be thereby reduced. 

55 Moreover, using the created web page, a user can easily 
locate printable documents on the website. 
[0013] In a further aspect, the present invention re- 
lates to a system in which a printer web page is provided, 
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a URL is entered into the provided web page, and a web 
page is created based on contents of the website, the 
web page including hypertext links. A link is selected 
and a command is issued to access a directory corre- 
sponding to the link. If the command fails, a document 
file is retrieved corresponding to the link. If the command 
is successful, a new web page is created including hy- 
pertext links. 

[001 4] This brief summary has been provided so that 
the nature of the invention may be understood quickly. 
A more complete understanding of the invention can be 
obtained by reference to the following detailed descrip- 
tion of the preferred embodiments, which are described 
by way of example only with reference to the attached 
drawings in which: 

[0015] Fig. 1 is an outward view of a hardware con- 
figuration embodying an embodiment of the present in- 
vention. 

[0016] Fig. 2 is a block diagram of a personal compu- 
ter internal architecture. 

[001 7] Fig. 3 is a functional block diagram of a printer 
expansion board according to an embodiment of the 
present invention. 

[0018] Fig. 4 is a functional block diagram of a web 
server. 

[0019] Fig. 5 is a flow diagram of computer-executa- 
ble process steps to print an Internet-located document 
in accordance with an embodiment of the present inven- 
tion. 

[0020] Fig. 6 is a view of a printer web page for use 
in conjunction with an embodiment of the present inven- 
tion. 

[0021] Fig. 7 is a view of a printer web page for use 
in conjunction with an embodiment of the present inven- 
tion. 

[0022] Fig. 8 is a flow diagram of computer-executa- 
ble process steps to browse remote web sites for print- 
able documents in accordance with an embodiment of 
the present invention. 

[0023] Fig. 9 is a view of a remote browsing printer 
web page for use in accordance with an embodiment of 
the present invention. 

[0024] Fig. 10 is a view of a remote browsing printer 
web page for use in accordance with an embodiment of 
the present invention. 

[0025] Fig. 11 is a view of a prior art web page dis- 
playing contents of a web server. 
[0026] Fig. 1 2 is the raw HTML of the image shown in 
Fig. 11. 

[0027] Fig. 13 is a flow diagram of computer-execut- 
able process steps to construct a server contents web 
page in accordance with an embodiment of the present 
invention. 

[0028] Fig. 14 is a view of HTML source code for a 
web page constructed using the Fig. 13 steps. 
[0029] Fig. 1 5 is a view of a web page displayed by a 
web browser based on the Fig. 14 source code. 
[0030] Fig. 1 6 is a view of a web page created in ac- 



cordance with an embodiment of the present invention. 
[0031] Fig. 17 is a view of a remote browsing printer 
web page for use in accordance with an embodiment of 
the present invention. 
5 [0032] Fig. 18 is a list of files and directories stored 
on a server. 

[0033] Fig. 19 is a flow diagram of computer-execut- 
able process steps to construct a server contents web 
page in accordance with an embodiment of the present 

10 invention. 

[0034] Fig. 20 is a view of HTML source code for a 
web page constructed using the Fig. 19 steps. 
[0035] Fig. 21 is a view of a web page displayed by a 
web browser based on the Fig. 20 source code. 

15 [0036] Fig. 22 is a view of a web page created in ac- 
cordance with an embodiment of the present invention. 
[0037] Fig. 23 is a flow diagram of computer-execut- 
able process steps to print electronic mail according to 
an embodiment of the present invention. 

20 p)038] Fig. 24 is a view of a printer web page for use 
in printing electronic mail in accordance with an embod- 
iment of the present invention. 

[0039] Fig. 25 is a view of HTML source code of a mail 
printing web page according to an embodiment of the 
25 present invention. 

[0040] Fig. 26 is a view of a mail printing web page as 
displayed by a web browser based on the Fig. 25 source 
code. 

[0041] Fig. 1 is an outward view of a representative 
30 computing system utilizing an embodiment of the 
present invention. 

[0042] Computing equipment 1 is preferably an Intel® 
Pentium(B>-based computer executing a windowing op- 
erating system such as Microsoft Windows98®. Com- 
as puting equipment 1 includes display 2 for displaying im- 
ages to a user, keyboard 4 for entering text and com- 
mands into appropriate fields displayed on display 2, 
and pointing device 5, such as a mouse, for pointing to, 
selecting and manipulating objects displayed on display 
40 2. 

[0043] Fixed disk 6 stores data files and computer- 
executable process steps of the windowing operating 
system and of other applications and device drivers ex- 
ecuted by computing equipment 1 . 

45 [0044] Floppy disk drive 7 provides an interface to 
computing equipment 1 for reading data from and writ- 
ing data to a floppy disk inserted therein. Using floppy 
disk drive 7, computer-executable process steps and/or 
data files may be input to computing equipment 1 and 

so stored on fixed disk 6. Computer-executable process 
steps and data files may also be retrieved over a net- 
work via network connection 9, and over telephone line 
1 1 , which connects to Internet 12. These files are trans- 
ferred thereto by web servers such as web server 14. 

55 Specifically, in response to a req uest for data and/or web 
pages, server 14 collects the required data, properly for- 
mats the data, and sends the data over Internet 1 2 to a 
web browser application executing in computing equip- 
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ment 1 . 

[0045] Computing equipment 1 can also upload data 
to Internet 12 via telephone line 11 . In this regard, com- 
puting equipment 1 may execute an electronic mail (e- 
mail) application to upload an e-mail message to Inter- 
net 12 for eventual delivery to an appropriate electronic 
mailbox. 

[0046] Printer 13 is preferably a high-volume laser 
beam printer but may also be an inkjet, dot matrix or 
other type of printer. As will be discussed below, printer 
1 3 is used to print documents and electronic mail locat- 
ed on Internet 12. 

[0047] Fig. 2 is a block diagram of the internal archi- 
tecture of computing equipment 1 . Shown in Fig. 2 is 
CPU 15, which, as described above, is preferably a Pen- 
tium® processor. CPU 1 5 interfaces to computer bus 1 6, 
as does modem interface 1 7 for interfacing to telephone 
line 11, network interface 19 for interfacing to network 
connection 9 and display interface 21 for interfacing to 
display 2. Mouse interface 22, which interfaces to 
mouse 5, and keyboard interface 24, which interfaces 
to keyboard 4, are also connected to bus 16. In this re- 
gard, interfaces 17 to 24 allow computing equipment 1 
to access the functionality of their corresponding com- 
ponents. 

[0048] Also shown in Fig. 2 is disk 6, having stored 
thereon the aforementioned windowing operating sys- 
tem, and computer-executable process steps of a web 
browser application, other applications, device drivers 
and data files. 

[0049] Read only memory (ROM) 25 stores invariant 
computer-executable process steps for basic system 
functions such as basic I/O, start-up, or reception of key- 
strokes from keyboard 4. 

[0050] Random access memory (RAM) 26 provides 
CPU 15 with memory storage which can be accessed 
quickly. In this regard, computer-executable process 
steps of a web browser or other application are trans- 
ferred from disk 6 over computer bus 1 6 to RAM 26 and 
executed therefrom by CPU 15. 
[0051] Fig. 3 is a functional block diagram of network 
expansion board 30 which resides in printer 13. Included 
in board 30 are TCP/l P layer 31 , which receives Internet 
Protocol (IP) packets from Internet 12, places them in a 
proper sequence, and parses data therefrom. TCP/IP 
layer 31 then ships the data to embedded web server 
32, which is a Hypertext Transfer Protocol (HTTP) serv- 
er capable of acting on the received data. One such ac- 
tion is to create appropriate Hypertext Markup Lan- 
guage (HTML) pages using HTML forms module 33. 
[0052] Pull-down Printing (PDP) module 35 contains 
computer-executable process steps to retrieve a net- 
work document or electronic mail from Internet 12based 
on a URL or mailbox information received from server 
32, and to format the received data for display by a us- 
er's web browser. PDP module 35 utilizes functions pro- 
vided by function libraries HTTP 36, FTP 37, HTTPS 39 
and POP3 40 in order to send requests and interpret 



responses based on these protocols. In this regard, 
PDP module 35 is directly connected to TCP/IP layer 31 . 
[0053] Expansion Protocol (XP) module 41 receives 
requests to print from PDP module 35 and sends the 

5 requests to printer controller 43 to complete printing. In 
a preferred embodiment, board 30 includes functions 
and components other than those shown in Fig. 3, such 
as components for interpreting other network protocols 
and the like. It also should be noted that the components 

10 of Fig. 3 may also be located on a motherboard of printer 
13. 

[0054] Fig. 4 is a block diagram of several relevant 
components internal to server 14. Preferably, server 14 
is connected to Internet 12 via an Internet connection 

is (not shown), which may be a telephone line, a T1 line, 
a local area network connection or the like. In a case 
that server 14 connects directly to a local area network, 
the local area network is preferably connected to a rout- 
er, which, in turn, is connected to Internet 12. In such a 

20 configuration, the router includes firewall software for 
prevention of unauthorized access to the local area net- 
work. It should be noted that although Fig. 4 shows HT- 
TP server 47 and POP3 server 50 contained within the 
same server, namely, server 14, the POP3 server and 

25 the HTTP server are not required to be in the same serv- 
er. 

[0055] Data packets received over Internet 12 (IP 
packets) travel to TCP/IP layer 46, which functions sim- 
ilarly to TCP/IP layer 31. In response to received IP 

30 packets, HTTP server 47 constructs web pages from 
HTML templates and image files stored in file storage 
49. Also stored in file storage 49 are documents, either 
in a printable format or another format, and Java ap- 
plets, which are programs executable by a Java Virtual 

35 Machine contained in a browser application. 

[0056] Upon receiving IP packets following the POP3 
protocol, TCP/IP Iayer46 parses the data therefrom and 
passes the data to POP3 server 50. POP3 server 50 is 
also connected to post office 51 , which is a data repos- 

40 rtory storing data of electronic mailboxes. POP3 server 
50 accesses post office 51 to respond to requests or 
instructions received by POP3 server 50 by sending ap- 
propriate data to a requestor via TCP/IP layer 46. Rel- 
evant details of the POP3 protocol will be discussed be- 

45 low. 

[0057] Fig. 5 is a flow diagram of computer-executa- 
ble process steps to print an Internet-located document 
according to the present invention. The process steps 
are preferably embodied in network expansion board 
50 30. 

[0058] In step S501 , embedded web server 32 re- 
ceives a request for a printer web page. The request is 
preferably provoked by entry of a URL corresponding to 
server 32 into a browser application executing on a us- 
55 er*s computing system such as computing system 1 . Af- 
ter such entry, the request is routed through Internet 12 
to server 32. In response to the request, a printer web 
page is created using HTML forms 33 and delivered to 
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the user in step S502. 

[0059] Fig. 6 shows printer web page 55 as displayed 
by a user's browser after step S502. As shown in the 
browser window, the URL corresponding to web server 
32 in the present instance is http://myneb/. Page 55 also 
includes input area 56 for entering a URL of a network 
document to be printed. In this regard, Fig. 7 shows 
page 55 after entry of a URL corresponding to a network 
document. 

[0060] After entry of the URL of a document in page 
55, the URL is received by web server 32 in step S504. 
Web server 32 includes process steps to route data re- 
ceived along with a request for page 55 to PDP module 
35. Therefore, PDP module 35 receives the URL and 
requests the document corresponding to the URL using 
functions of FTP library 37, since the received URL is 
an FTP site. 

[0061] In response to the request from PDP module 
35, the document is received in step S506. The docu- 
ment is then sent to printer controller 43 for printing in 
step S507. Preferably, the document is received in a 
print-rendered format in step S506. If not, printer con- 
troller 43 must render the document prior to printing. 
[0062] Fig. 8 is a flow diagram of computer-executa- 
ble process steps preferably embodied in expansion 
board 30 to browse a remote web site for printable doc- 
uments. 

[0063] Flow begi ns at step S80 1 , wherein web server 
32 receives a request for a remote browsing web page 
due to a corresponding URL being entered into a user's 
browser application . Server 32 creates such a web page 
using HTML forms 33 and delivers the page to the re- 
questing browser in step S802. Fig. 9 shows remote 
browsing page 60 delivered in step S802. As also 
shown, the URL use to request page 60 is http^/myneb/ 
pdpbrowse.html. 

[0064] A user then enters a URL into input area 61 of 
page 60 as shown in Fig. 10. The URL is submitted to 
Internet 12 by selection of Submit icon 62. In step S804, 
the URL is received by server 32. 
[0065] Diverting from the Fig. 8 flow, Fig. 11 shows 
contents of the web site specified by the URL entered 
into input area 61 , as conventionally displayed by a web 
browser. In this regard, the URL was entered into URL 
input area 65 of the web browser and the directory con- 
tents of the URL were provided to the browser in the 
format shown in Fig. 11 . The HTML source code corre- 
sponding to the Fig. 11 display is shown in Fig. 12. Con- 
sidering Fig. 11, it can be seen that Fig. 11 contains 
much data not needed by a user to select a document 
for printing. Moreover, selecting an underscored link 
shown in Fig. 11 would not result in printing of an asso- 
ciated document. 

[0066] Returning to Fig. 8, a Directory Open com- 
mand is transmitted in step S805 using the URL re- 
ceived in step S804. If the command is successful, flow 
continues from step S806 to step S807, wherein direc- 
tory data such as that shown in Fig. 1 2, which is received 



due to the Open Directory command, is converted into 
an HTML format according to the present invention in 
step S807. 

[0067] Fig. 13 illustrates a flow diagram of computer- 
5 executable process steps used in step S807 to convert 
directory data from an HTTP-based web site into an 
HTML format according to an embodiment of the 
present invention. 

[0068] In step S1301, the HTML directory data is 
10 searched for the HTML parameter "A". If the parameter 
is not located, the Fig. 13 process steps terminate. If so, 
flow continues to step S1 302 to locate a corresponding 
"HREP parameter. Considering the Fig. 12 example, 
the first qualifying parameter located during the Fig. 13 
15 process correspond to the actual link 7big.ps n and the 
corresponding display big.ps. 

[0069] After location of an HREF parameter in step 
S1302, the corresponding actual link and display infor- 
mation are parsed in step S1304. In the foregoing ex- 

20 ample, the parsed link is "/big-ps" and the display infor- 
mation is big.ps. Next, in step S1305, a new HREF state- 
ment is created, using the format <A HREF="pdp- 
browse.html?target_url=(actual link) u >display informa- 
tion </A>. I n the present example, the statement created 

25 in step S1 305 would read <A HREF="pdpbrowse.html? 
target_url=http7/1 46.1 84.23. 1 6:80 /big.ps M >big.ps</ 
A>. Flow returns from step S1305 to step S1301 and 
continues as described above. 
[0070] Fig. 14 shows HTML source code created by 

30 application of the Fig. 13 process steps to the Fig. 12 
source code in step S807. The page is delivered in step 
S809. Fig. 15 shows remote browsing web page 70 dis- 
played by a browser based on the Fig. 14 source code. 
It should be noted that selection of a hyperlink displayed 

35 in Fig. 1 1 merely results in an attempt to open a directory 
having a name identical to the hyperlink. In contrast, se- 
lection of a link of page 70 results in a target URL being 
passed in step S810 to remote browsing web page 60 
"pdpbrowse.htmr as explained with respect to Fig. 10. 

40 As a result, flow returns to step S805 to transmit an 
Open Directory command with respect to the new target 
URL. 

[0071 ] Next, if the command is not successf u I, it is as- 
sumed that the target URL corresponds to a document 

45 rather than a directory and submit page 80 of Fig. 1 6 is 
delivered in step S811 . Upon selection of the displayed 
link, web page 55 of Fig. 6 is preferably passed the tar- 
get URL. Therefore, as described above, web server 32 
passes the target URL to PDP module 35 to retrieve a 

50 corresponding document in step S814 and to print the 
document in step S815. 

[0072] Fig. 17 shows remote browsing web page 60 
having a URL of an FTP-enabled web site entered into 
input area 61 . The URL is received in step SB04 of Fig. 
55 8 and flow proceeds as described above until step S807. 
[0073] Fig. 1 8 shows a display of directory data from 
the FTP-enabled web site corresponding to the URL re- 
ceived in step S805. Since the FTP directory data is in 
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a format different from the HTTP directory data, process 
steps different from those shown in Fig. 13 are needed 
to perform step S807. 

[0074] In this regard, Fig. 1 9 is a flow diagram of com- 
puter-executable process steps to create a directory 5 
web page similar to that created by the Fig. 13 process 
steps but in the case of an FTP-enabled web site. The 
process steps are also preferably embodied in network 
expansion board 30. In the present example, the Fig. 19 
process steps act on the Fig. 1 8 data. 10 
[0075] Initially, in step S1901, the directory data is 
parsed to obtain a list of filenames therein. Next, in step 
S1 902, a first filename is retrieved. A corresponding hy- 
perlink statement is created in step S1 904. The state- 
ment uses the following format: <A H REF= M pdpbrowse. 15 
html?target_url-ftp://username:password ©ftp.micro- 
soft.com/./filename</A>. 

[0076] If more filenames exist, flow continues from 
step S1 905 to step S1 906 to obtain a next filename and 
a new statement is created in step S1904. If no more 20 
filenames exist at step S1 905, the process steps termi- 
nate. Fig. 20 shows HTML source code of a page cre- 
ated by applying the Fig. 19 process steps to the Fig. 
1 8 data. As described with respect to Fig. 8, the page is 
delivered in step S809 and thereafter displayed as 25 
shown in Fig. 21. 

[0077] Upon selection of a link shown in Fig. 21 , a tar- 
get URL corresponding to the link, as defined by the Fig. 
20 source code, is passed to with the URL of "pdp- 
browse.htmr page 60 for browsing of a site correspond- 30 
ing to the target URL. It should be noted that PDP mod- 
ule 35 determines which protocol to use when browsing 
a site by referring to the target URL passed with the 
"pdpbrowse.html" URL. If the target URL does not cor- 
respond to a directory, a web page such as that shown 35 
in Fig. 22 is delivered in step S81 1 and the Fig. 8 process 
steps continue as described above. 
[0078] Fig. 23 is a flow diagram of computer-execut- 
able process steps to print electronic mail on a remote 
printer. The process steps are preferably embodied in 40 
expansion board 30. 

[0079] A request for a mail printing web page is re- 
ceived in step S2301 , as a result of a user entering an 
appropriate URL into a web browser. In response, a mail 
printing web page such as page 90 of Fig. 24 is deliv- 45 
ered. As shown in Fig. 24, the appropriate URL corre- 
sponding to page 90 is http://myneb/pdppop3.html. 
[0080] A user enters data into the fields shown on 
page 90 including a message number 92 that the user 
wants to view or print, and submits the data by selecting so 
submit icon 91. It should be noted that a message 
number 92 of 0 indicates that the entire contents of the 
mailbox will be returned in browsable form, thus facili- 
tating browsing of the mailbox. Once in browsing mode, 
the user can select a specific mail message and chose 55 
to view it or print it. The data is thereafter received in 
step S2304 by being passed as parameters to the 
"pdppopS.htmr URL. 



[0081] After reception of the data, a corresponding 
mailbox is accessed by PDP module 35 using the data 
and the POP3 protocol. Next, in step S2306, the "List" 
POP3 command is used to determine the number of 
messages in the corresponding mailbox and the number 
is checked against the message number received in 
step S2304. If the number of messages in the mailbox 
is less than the received number, an error web page is 
delivered requesting reentry of the message number to 
print. If not, flow continues to step S2307. 
[0082] In step S2307, headers of the specified mes- 
sage^) is/are retrieved. If a message number of 0 was 
selected by the user to enter browsing mode, a web 
page is created in step S2309 to display the header data 
regarding the retrieved messages. If however, the user 
entered a specific mail message number, then the se- 
lected mail message will be printed and steps S2309 
and S2310 are skipped. Source code for such a page is 
shown in Fig. 25. After the page is delivered, it is dis- 
played on the user's browser as shown in Fig. 26. If a 
"Print this message" link is selected, a print command 
is received in step S2310. In response, PDP module 35 
retrieves the corresponding message and delivers the 
message to printer controller 43 for printing in step 
S2311. 

[0083] In an alternative embodiment, a user can use 
remote browsing page 60 to request printing of electron- 
ic mail. In this embodiment, a user enters a URL such 
as "pop3://user: password ©mailserver /message 
number" to specify the data requested by web page 90. 
Then, when the URL is passed as a target_uri parame- 
ter to the URL of page 60, PDP module 35 parses the 
necessary data from the target_url and flow continues 
from step S2305 as described above. One drawback to 
the foregoing embodiment is that the password data 
would be visible upon entry into page 60. 
[0084] Although the present invention has been de- 
scribed with respect to what are currently considered to 
be its preferred embodiments, the invention should not 
be deemed to be limited thereto. Rather, the invention 
is intended to encompass all equivalent and obvious 
modifications and embodiments contained within the 
scope and spirit of the appended claims. 

Claims 

1 . A method for providing print-by-reference function- 
ality to a web browser, the method comprising: 

providing a web page from a printer's embed- 
ded web server to the web browser; 
receiving a URL entered into the provided web 
page by the web browser; 
retrieving a printable document corresponding 
to the URL; and 
printing the retrieved document. 
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2. A method according to Claim 1 , wherein the web 
page is in HTML format. 

3. A method according to Claim 1 , wherein the web 
page is in XML format. s 

4. A method according to Claim 1 , wherein the docu- 
ment is in a print-ready format. 



a providing step to provide a web page from a 
printer's embedded web server to the web 
browser; 

a receiving step to receive a URL entered into 
the provided web page by the web browser; 
a retrieving step to retrieve a printable docu- 
ment corresponding to the URL; and 
a printing step to print the retrieved document. 



5. A method according to Claim 1 , further comprising 10 1 1 . Process steps according to Claim 1 0, wherein the 
converting the document to a print-ready format. web page is in HTML format. 



6. A method for browsing the contents of a remote 
website, the method comprising: 



15 



providing a web page from a printer's embed- 
ded web server to a web browser; 
receiving a URL entered into the provided web 
page, the URL corresponding to a website hav- 
ing a transfer protocol not supported by the web 20 
browser; and 

creating a web page based on contents of the 
website, the web page including a link to a di- 
rectory, a link to a document, or links to a direc- 
tory and a document, 25 
wherein, if a link to a directory is selected, a new 
web page is created including a link to a subdi- 
rectory, a link to a document, or links to a sub- 
directory and to a document. 

30 

7. A method according to Claim 6, wherein the web 
page is accessed using HTTP, and the entered URL 
corresponds to a FTP using website. 

8. A method for providing browsing of a remote web- 35 
site, the method comprising: 

providing a web page to a browser; 
receiving a U RL entered into the web page from 
a web browser, the URL corresponding to a re- 40 
mote website; 

creating a web page based on contents of the 
website, the web page including hypertext 
links, selecting a link; and 

issuing a directory access command corre- 45 
sponding to the link, 

wherein, if the command fails, a document is 
retrieved corresponding to the link, and 
wherein, if the command is successful, a new 
web page is created having hypertext links. so 

9. A method according to Claim 8, further comprising 
printing the document. 

10. Computer-executable process steps stored on a 55 
computer-readable medium, the steps to provide 
print-by-reference functionality to a web browser, 
the steps comprising: 



12. Process steps according to Claim 10, wherein the 
web page is in XML format. 

13. Process steps according to Claim 10, wherein the 
document is in a print-ready format. 

14. Process steps according to Claim 10, further com- 
prising a converting step to convert the document 
to a print-ready format. 

15. Computer-executable process steps stored on a 
computer-readable medium, the process steps to 
browse the contents of a remote website, the proc- 
ess steps comprising: 

a providing step to provide a web page from a 
printer's embedded web server to a web brows- 
er; 

a receiving step to receive a URL entered into 
the provided web page, the U RL corresponding 
to a website having a transfer protocol not sup- 
ported by the web browser; and 
a creating step to create a web page based on 
contents of the website, the web page including 
a link to a directory, a link to a document, or 
links to a directory and a document, 
wherein, if a linkto a directory is selected, a new 
web page is created including a linkto a subdi- 
rectory, a link to a document, or links to a sub- 
directory and to a document. 

16. Process steps according to Claim 15, wherein the 
web page is accessed using HTTP, and the entered 
URL corresponds to a FTP using website. 

17. Computer-executable process steps stored on a 
computer-readable medium, the process steps to 
provide browsing of a remote website, the process 
steps comprising: 

a providing step to provide a web page to a 
browser; 

a receiving step to receive a URL entered into 
the web page fro ma web browser, the URL cor- 
responding to a remote website; 
a creating step to create a web page based on 
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contents of the website, the web page including 
hypertext links, selecting a link; and 
an issuing step to issue a di rectory access com- 
mand corresponding to the link, 
wherein, if the command fails, a document is 
retrieved corresponding to the link, and 
wherein, if the command is successful, a new 
web page is created having hypertext links. 

18. Process steps according to Claim 17, further com- 
prising a printing step to print the document. 

19. A method according to Claim 1, wherein the URL 
contains e-mail account identification information. 

20. A method according to Claim 1 9, wherein the web 
page allows entry of the e-mail account identifica- 
tion information. 



31 . A signal conveying computer-executable process 
steps according to at least one of claims 1 0 to 17 
and 25 to 30. 

5 32. A software product programmed with processor-im- 
plementable instructions for carrying out a method 
according to at least one of claims 1 to 9 and 19 to 
24. 

10 33. A software product according to claim 32 in the form 
of a signal conveying said processor-implementa- 
ble instructions. 

34. A printer incorporating a software product accord- 
's ing to claim 32. 



21 . A method according to Claim 6, wherein the URL 20 
contains e-mail account identification information. 

22. A method according to Claim 21 , wherein the cre- 
ated web page contains information retrieved from 
the e-mail account re-formatted into web format. 25 



23. A method according to Claim 8, wherein the URL 
contains e-mail account identification information. 



24. A method according to Claim 23, wherein the ere- 30 
ated web page contains information retrieved from 
the e-mail account re-formatted into web format. 



25. Computer-executable process steps according to 
Claim 1 0, wherein the URL contains e-mail account 35 
identification information. 



26. Computer-executable process steps according to 
Claim 25, wherein the web page allows entry of the 
e-mail account identification information. 40 



27. Computer-executable process steps according to 
Claim 1 5, wherein the URL contains e-mail account 
identification information. 

45 

28. Computer-executable process steps according to 
Claim 27, wherein the created web page contains 
information retrieved from the e-mail account re-for- 
matted into web format. 

50 

29. Computer-executable process steps according to 
Claim 1 7, wherein the U RL contains e-mail account 
identification information. 



30. Computer-executable process steps according to 55 
Claim 29, wherein the created web page contains 
information retrieved from the e-mail account re-for- 
matted into web format. 
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<headxtitle>/ - </litle></headxbody><H1>/- </H1xhr> 

<pre> 12/3/96 10:37 AM 14418677 <A HREF="/big.ps*>big.ps</Axbr> 
6/3/96 1:08 AM 314344 

<A HREF=7BOUKEN.JPG">BOUKEN.JPG</Axbr> 1 1/1 4/97 5:05 PM 
1017591 <A 

HREF="/bouken.pcr>bouken.pcl</Axbi> 11/14/97 5:22 PM 3866574 
<A 

HREF="/bouken.ps">bouken.ps</Axbr> 4/22/98 10:46 PM 59039 <A 
HREF=7cbaloon.pcl">cbaloon.pcl</Axbr> 4/22/98 10:56 PM 25038 <A 
HREF=7guy.pcl">guy.pcl</Axbr> 6/3/97 11:14 AM 9067 <A 

HREF=7LICENSE.PDP>LICENSE.PDF</Axbr> 6/3/96 12:42 AM 
170420 <A 

HREF=7MACHIBOU.JPG">MACHIBOU.JPG</Axbr> 11/14/97 6:15 PM 
804335 <A 

HREF=7machibou.pcr>machibou.pcl</Axbr> 11/14/97 5:18 PM 
3362865 <A 

HREF=7machibou.ps">machibou.ps</Axbr> 6/7/96 7:07 PM 9877 <A 
HREF=7MICKEY.PS">MICKEY.PS</Axbr> 7/10/97 5:18 PM 2260162 
<A 

HREF=7NETBIOS.PCL">NETBIOS.PCL</Axbr> 8/6/99 2:23 PM 
81408 <A 

HREF=7posta.doc">posta.doc</Axbr> 8/24/99 7:53 PM 5393 <A 

HREF=7posta.htmr>posta.html</Axbr> 8/19/99 1:58 PM 6243 <A 

HREF=7posta2.htmr>posta2.html</Axbn> 2/17/98 9:18 PM 2004 <A 
HREF=7potato50.bat">potato50.bat</Axbr> 4/12/97 3:37 AM 141721 
<A 

HFEF=7PRESENT.JPG">PRESENT.JPG</Axbr> 11/14/97 6:12 PM 
950883 <A 

HFEF=7present.pcr>present.pcl</Axbr> 11/14/97 5:14 PM 3097176 
<A 

HREF=7present.ps">present.ps</Axbr> 6/3/96 1:40 PM 294591 
<A 

HREF=7RUGGEDP.JPG">RUGGEDP.JPG</Axbr> 11/14/97 6:12 PM 
1227109 < A 

HREF=7ruggedp.pcl">ruggedp.pcl</Axbr> 11/14/97 5:20 PM 
3097174 <A 

HREF=7ruggedp.ps">ruggedp.ps</Axbf> 6/2/96 7:51 PM 169895 
<A 

HREF=7SANPO.JPG">SANPOJPG</Axbr> 11/14/97 6:13 PM 
561124 <A 

HREF=7sanpo.pcr>sanpo.pcl</Axbr> 11/14/97 5:13 PM 3097176 
<A 

HREF=7sanpo.ps°>sanpo.ps</Axbr> 12/1/95 8:56 M 78519 <A 

HREF=7TIGER.PS">TIGER.PS</Axbr> 8/10/99 5:31 PM 468 <A 

HREF=7ufp.htmr>ufp.html</Axbrx/prexhr></body> 
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<P> 

<A HREF= w pdpbrowse.html?target_url=httpy/1 46. 1 84.23. 1 6:80foig.ps w >big.ps</a><BR> 

<A HR EF="pdpbro wse.html?target_uri=httpy/1 46. 1 84.23. 1 6:80/bouken. jpg->bouken.jpg</a><BR> 

<A HREF="pdpbrowse.html?target_ur1=http://1 46. 1 84.23.1 6:80/bouken.pcl%bouken.pcl</axBR> 

<A HREF="pdpbrowse.html?target„url=httpy/1 46.1 84.23. 16:80/bouken.ps%bouken.ps</axBRx 

<A HREF="pdpbrowse.html?target_uri^ttp7/146.184.23.16:8(Vcbaloon.pd*>cbal 

<A HREF= w pdpbrowse.html?target_ui1=httpy/1 46. 1 84.23. 1 6:8Q/guy.pcr>guy.pd</axBR> 

<A HR EF="pdpbrowse.html?targeLurl=hltpy/1 46. 1 84.23. 1 6:8Qflicense.pdf%license.pdf </axBR> 

<A 

HREF="pdpbrowse.html?target_url=hUp://l 46. 1 84.23. 1 6:80/machibou.jpg^machibou.jpg</axBR> 
<A 

HREF="pdpbrowse.hrml?target_url=hltp://1 46.1 84.23. 16:80/machibou.pcr>machibotj.pcl</a><BR> 
<A 

HREF="pdpbrowse.html?target_url==http://1 46. 1 84.23. 1 6:80/machibou.ps%machibou.ps</axBR> 
< A HREF="pdpbrowse.html?target_ur1=http://1 46. 1 84.23. 16:80/mickey.ps">mickey.ps</a><BR> 
< A HREF="pdpbrowse.html?target_uri=http7/1 46. 1 84.23. 1 6:80/netbios.pcr>netbios.pd</axBR> 
< A HR EF="pdpbrowse.html?larget_urf=httpy/ 1 46. 1 84.23. 1 6:80/posta.doc">posta.doc</axBR> 
<A HREF="pdpbrowse.html?target_url=http7/1 46. 1 84.23. 16;8(Vposta.htmr>posta.html</a><BR> 
<A HREF="pdpbrowse.html?target_url^t^ 
<A 

HREF="pdpbrowse.html?target - url^ttpy/146.184.23.16.80/potato50.bat%potato50.bat 
<A HREF=>dpbrowse.html?taiget_urt^ 

<A HREF-"pdpbrowse.html?target_uri^ttp7/146.184.23.16:8Q/present.^">prese 
<A HREF="pdpbrowse.html?target_url=http7/1 46.184.23. 16:80/present.ps">present.ps</axBR> 
<A HREF=>dpbrowse.html?target_url=http-y/1 46.184.23. 16:80/ruggedp.jpg">ruggedp.jpg</a><BR> 
<A HREF="pdpbrowse.htmI?target_ur1=http7/1 46. 1 84.23. 1 6:80/aiggedp.pcI">ruggedp.pcl</axBR> 
<A HREF="pdpbfowse.html?target_uri=httpy/1 46. 1 84.23. 1 6:80/ruggedp.ps">ruggedp.ps</axBR> 
<A HREF="pdpbrowse.html?target„ur1=^ttp7/1 46. 1 84.23. 16:8Q/sanpo.jpg">sanpo.jpg</axBR> 
<A HREF="pdpbrowse.htm»?target_ur1=http7/1 46. 1 84.23. 1 6:80/sanpo.pcT>sanpo.pcl</axBR> 
<A HREF= w pdpbrowseiitml?tafget_ur1=httpy/1 46. 1 84.23. 1 6:80/sanpo.ps">sanpo.ps</axBR> 
<A HREF="pdpbrowse.html?target_url=httpy/1 46. 1 84.23. 1 6:80/tiger.ps">tiger.psc/a><BR> 
<A HREF=>dpbrowseJitml?target_urf^ttp*y/^ 

</P> 

</BODY> 
</HTML> 
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<P> 

<A hreb"pdpbrovyrse.html?targeLuri^y/arK)nymous:anonym @flp.mk^osoft.com/7bussys">bussys<BR></A> 
<A 

href="pc^rowse.htm!?tafget_urt=ftp://anonymous:^ 
<A 

href=>Jpbrowse.htmi?(argeLurf=f^ 
<A 

<A 

hrei="pdpbrowse.hlml?largel_url=:ftpV/anonym^ 
<A 

hrel=>dpbrowse.html?^ ( B 

R></A> 

<A 

href=-pdpbrowse.html?largeLuri^tp7/anonynrK>us:a^ 

BR></A> 

<A 

h <ef="pdpbrow^ 

<A 

hreJ= N pdpbrowse.htmt?targeLurMtpy/anonyn»us:anony^ 

<A href="pdpbrov^e.hlrnl?target_url=ttp://anonymous:an^ comA/MR txT>ts- 

IR.Ixt<BR></A> 

<A ^ef="pdpbrav^h^^ 2<BR></A> 
<A href= pdpbrowse.html?target_^ ZIP">LS- 
LR.ZIP<BR></A> 



<A href= P^rowse.html?targe^ 

<A href= papb'wse.htm!?!^^^ 
href=-pdpbrowse.htfrt?targeLuri=f^ 
</P> ' 

FIG. 20 
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The following is a sample ol Ihc HTML generated by the embedded web server: 

<HTMI_> 
<HEAD> 

<title>Canon Browse For A Remote Ft\c<M\e> 
</HEAD> 

<BOOY bgColor=while> 
<P align=right> 

<STRONGxFONT color=gray tace=Times New Roman" size=3><A href ="index.htmr>Em bedded Web Scrverc/A> 
<BR> 

Status: ldlc</FONTx/STRONG> 

<BR> 

</P> 

<P aiign=center> 
<STRONG> 

<F0NT color =medium blue face="Times New Roman" sizc=5 style= M FONT-SIZE: x^arge"> 

Remote Browstng</FONT> 

</STRONG> 

<JP> 

<P> 

<STRONG> 

<FONT face-Times New Roman" size=3> 

Current Path: mafl_rissc.canon.com/<BR> 

</FONT> 

</STRONG> 

<JP> 

<P> 

<B>No.</B> 1<cBRxB>Si*e:</B>1999<BRxB>Date:</B> Mon, 30 Aug 1999 12:36:09 -0700<BRxB>From:</B> 
"Matsubayashi, Don" [0on_M3tsubayashi@cisscxanon.com]<BRxB>Subject:c/B>POSTA <BR> <B>Number of 
Hypertinks:</B> 3<BR> <A 

href="pdpJitml?tai^_ur1=pop3tf^ this message</A> 

&nbsp &nbsp &nbsp <A 

href="pdpviewiitrn!?targetjri^ 

message</AxBRxB>Hyperiinks for Message Mo. l:</BxBRxA 
href="pdpbrowseJUnri?target_^^ &rtbsp <A 

hre<=^ttps-i/www.yahooxom%https*y/www.yahooxom</A><BR><A 

href= w pdpbrowseJrtml?targ^tj^^ this:c/A> 

&nbsp <A href= N https://postaJumbleweea1xorrt^ 

5a6naou6%https://po$taaumbteweedxom/posta?x=^ 

href="pdpbrowse,html?target_uri=httpy/www.rx)StaxorTi* , > Print this:</A> &nbsp <A 
href="hnp:/Aflrww4>o$4axom%h^ 

1438<BRxB>Date:</B> Tue, 31 Aug 1999 00:39:47 -0700<BRxB>From:</B> "Purpura, Don" 
[Don Puipura@dssacanoacornJ<BR><B>Subject:</B> RE: MOIs 423, 430<BR> <B>Number of Hyperlinks :<iQ> 
0<BR> <A href= M pdpJitm!?targ^_ui1:=pop3:tf^ this 
message</A> &nbsp &nbsp &nbsp <A 

href ="pdpview.html?target_ui1=pop3 y/cisVdmatsuba :password@mail.dsscxarH>n.coni/2"> View this 

message</A><BR><BR> 

<]?> 

</BODY> 
</HTML> 
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a Canon Browser For A Remote Flte-Klcrasoft Internet Explorer 
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Size: L999 
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Subject: POSTA 

Number of Hyperlinks: 3 

Print this message View this message 
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Print this: httDs://www yahoo.com 
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